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РНР.проекте 
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гетайсит ака 5 ЗИ. сом 


° ВаВ бааф 

° Автоматизация еСоттегсе и ритейла 

®° >5000 клиентов в России и за рубежом 
® 50% интернет-магазинов в России 


® Команда разработки >50 человек 


гетайсит ака 5 ЗИ. сом 


. 250 раге тета! 
. >50 серверов БД 
* ЛООСОСОО0 195 


О чем будем говорить 


* Подключение к Ро эгеъ о! 
° Управление схемой данных 
° Миграции 


. Индексы 


Пара терминов в докладе 


° Модель данных — структура БД, описанная в 
приложении (на уровне моделей Вос\гте) 


° Схема данных — структура в Роз егез Е 
(таблицы, поля, констрейнты и т.п.) 


Подключение к Роз%&2ге ОЕ. 


СоппесЧоп роо|!ег 


=, РНР Ризза 
2022 


РНР -› Роз{вге ОЁ 


Патарбазе 


НТТР Соппесйопз 


Кеаче=з 
р 
> 
А 
а 


РНР-ЕРМ Роз&=ге ЗО |. 


Ро РНР Ризза 
2022 


РНР - Роз{=ге 5 ОЁ 


<?рИр 


ФраСоппесЕ1оп = Босфг1пе\ОВАЕ\Ог1\уегМападег : : де СоппесЕ1оп ([ 
'Чбпате' => '4ето', 

'агтмее' =» 'роо_ро50е’, 

' Розе ' — "'розфдге$_По$е', 

` Боге ` Оо, 

| 


фэфафетеп: ФраСоппес1оп—>ехеси{е(иегу ('5ЗЕТЕСТ +1г5*_пате РЕКОМ узег ЕТМТТ 100'); 


р, Кизэа 
2 


РНР -› Роз{вге ОЁ 


Патарбазе 


НТТР Соппесйопз 


Кеаче=з 
р 
> 
А 
а 


РНР-ЕРМ Роз&=ге ЗО |. 


и Ро РНР Визза 
2022 


РНР -> Р=Боицпсег -+ Роз&2ге 5 ОЁ 


НГГР 


Кеачез{$ 


РНР-ЕРМ 


РеБоипсег 


Соппесйопз 


Р=Боцисег 


Патарбазе 


Соппесчоп$ 


Роз&=2ге О. 


=, РНР Виза 
2022 


РНР > РеБоцпсег -? Роз%&2ге 5 ОЁ 


<?рИр 


ФраСоппесЕ1оп = Босфг1пе\ОВАЕ\Ог1уегМападег : : де Соппес1оп ([ 
'абпате' 'аето', 
'Аг1\уег' 'р9о_р9$91', 
' Розе ' 'рабоупсег_По$е', 
Боге ' 6432, 
р 


$ъфафетеп* = М ехеси{е(иегу (' ЗЕТЕСТ +11г5$*_пате РЕКОМ изег (ТМТТ 100'); 


ри Кизэа 
2 
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Эмуляция регулярных коннектов к БД 


<?рпр 


$формафсН = пем ЗбутЕопу\Сотропеп+\ $ орматсН\ $ ормасй (гие); 
$Фсоппес+1опРагат$ = [ /* ... х/ ]; 


Рог ($1 = 0; $1 < 500; $1++) 4 
ФраСоппесЕ1оп = Босг1пе\ОВАЕ\Ог1\уегМападег : : де СоппесЕ1 оп ($соппесЕ1опРагат$); 


$эформафсп—>$аг*('ЧБа\', 'аба\т'); 
ФраСоппесЕ1оп—>ехесиедиегу ('ЗЕЁТЕСТ Е1г$%_пате ЕВОМ узег ЕТМТТ 100'); 


$зформафснй—>$ор(' арбат '); 


фэформатсн—гезет(); 
фроСоппес+1оп—сТозе (); 


Кизэа 


РНР+Р= уз РНР+Рэ=Бочцптсег+Р= 
ОВАЕ Роэз{эеге 5 ОГ 2,58 те 


ОВАЕ Ребоипсег @©О.БО тз = 


С-ТРозеэгезо ОИ т$ 


Чето= ЗЕЁЕСТ +1г$%_пате РЕКОМ узег |ТМТТ 1900; 


(100 строк) 


Время: 0,412 мс 


=, РНР Низза 
2022 


НТТР 


Агспкесхоиге: РНР + Р=Боипсег + Р= 


Вариант1 


Арр зегуег ОВ зегуег 


Ро РНР Визза 
2022 


НТТР 


Агспкескиге 


Вариант 2 


: РНР + РеБоипсег + Р= 


Арр зегуег 


ОВ зегуег 


Агсбкесхоге: РНР + Р=Боипсег + Р= 


Вариант1 

+ Точка коннекта ближе к приложению 

+ Индивидуальные настройки рэроипсег 
— Сложность конфигурирования 


— Контроль за общим числом коннектов к СУБД 


=, РНРРизза 
2022 
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Аналоги р=Боцпсег 


Оауззеу от Яндекс ПИр$./=(Пчб.сот/уапаех/оауззеу 


ргаггоа! ПЦр5://=кпуб.сот/аэ»гоа/рэ=аэгоа! 


РНР -> Р=Боипсег -? Роз%&2ге 5 ОЁ 


+ Переиспользование коннектов к Ро эгез 1+ 
+ Ускорение 501! -запросов (особенно легких) 


+ Экономия ресурсов СУБД на создание 
соппесЧоп5 


+ Контролируемый «барьер» при резком 
увеличении нагрузки 


Титеоц(з 


=, РНР Низза 
2022 


Медленный 5ОЁ-запрос 


тах_ехеси{Топ_11те = 


60 $ес 


РНР-ЕРМ 


Роз&=ге ОЕ. 


Ро РНР Виза 
2022 


Медленный 5ОЁ-запрос 


тах_ехеси{Топ_11те = 
60 ес 


НТТР-запрос 


——> 


РНР-ЕРМ 


22 


Роз&=ге ОЕ. 


Ро РНР Виза 
2022 
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Медленный 5ОЁ-запрос 


тах_ехеси{Топ_11те = 
60 ес 


НТТР-запрос 


——> 


501:-запрос 


РНР-ЕРМ 


Роз&=ге ОЕ. 


Ро РНР Виза 
2022 


Медленный 5ОЁ-запрос 


тах_ехесиТоп_11те = 


60 $ес Долгий ЗОЕ. 
запрос 


—* > 


НТТР 504 


РНР-ЕРМ 


24 


Роз&=ге ОЕ. 


Ро РНР Виза 
2022 


25 


Медленный ЭОЁ-запрос 


Долгий $О01- 
запрос 
60 $ес : 
Долгий $О01- 
запрос 
а 
Долгий $О01- 
запрос 


— 


тах_ехеси{Топ_11те = 


НТТР 504 


НТТР 504 


НТТР 504 РНР-ЕРМ 


Роз&=ге ОЕ. 


Ро РНР Виза 
2022 


Тайм-аут выполнения запросов 


=, РНР Визза 
2022 


27 


Тайм-аут выполнения запросов 


# соп+19/расКаде$ /дос+г1пе. уат\ 


Чостгтпе: 
дра\т: 
игТ: '%епу(гезо\Туе : ВАТАВАЗЕ_ЦВЕ)%' 
ор{1оп$: 
$фафтетеп+_+1теоц*: '%епу(гезо\ме : РО Е_5ТАТЕМЕМТ_ТТМЕОИТ)%' 


а 
2022 


Кизэа 


Тайм-аут выполнения запросов 


Арр0глуег Ог1уег 
( $рагам$)) 


$Чг1\мег0рЕ1оп$ = $рагат$[ 


$соппесЕ1 оп Соппес1оп ($р90); 
$соппесЕ1 оп (оргтнЕЕС 


$Чг1\мег0рЕ1оп$ [ 


$соппесетоп; 


Тайм-аут выполнения запросов 


Для СТ в .епу ставим более высокие таймауты 


Нельзя выставлять в Роз&=2ге О 
Выставляем только на уровне приложения 


Из документации Роз егез о 


зецтя эзацетеп_{итеоцЕ ш роз{егеза|соп{ 1$ по* 
гесоттепаеа бБесаизе к моч!4 аНес* а! зеззопз. 


50 


=, РНР Ризза 
2022 
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Тайм-аут локов запросов 


Выставляем: 
1. или в рамках соппесчоп 


2. или науровне транзакций 


Управление схемои данных 
и миграции 


55 


Управление схемой в Вос*гпте 


.- Создали/изменили модель 
рЮр 61п/соп$оте маке: епе1+у Ргодис* 


Управление схемой в Вос*гпте 


- Создали/изменили модель 
рЮр 61п/соп$оте маке: епе1+у Ргодис* 


. Сгенерировали миграцию 
р—р 61п/соп$оТе таке: ттдога{1оп 


54 


Управление схемой в Вос*гпте 


- Создали/изменили модель 
рЮр 61п/соп$оте маке: епе1+у Ргодис* 


. Сгенерировали миграцию 
р—р 61п/соп$оТе таке: ттдга1оп 


. Применили миграцию 
рЮр 61п/соп5о1е досфг1те : ттога*1 оп : птдга*е 


55 


Управление схемой в Вос*гпте 


- Создали/изменили модель 
рАр 61п/сопзоте макКе : епЕ1 ту 


. Сгенерировали миграцию 
р—р 61п/соп$оТе таКе: ттдга1оп 


НЯ м 


56 


7. 


$ 
® `, * ре, 
\ Ге 


`, 
_^ „ноестьнюансы 


и 2022 


Кизза 


Управление схемой в Вос*гпте 


1. Миграции требуется дорабатывать 


=, РНР Ризза 
2022 


Управление схемой в Вос*гпте 


1. Миграции требуется дорабатывать 


2.Где доработки, там и ошибки 


=, РНРРизза 
2022 


Управление схемой в Вос*гпте 


1. Миграции требуется дорабатывать 
2.Где доработки, там и ошибки 


5.В итоге модель данных расходится со 
схемой данных 


Контроль соответствия модели 
и схемы данных 


7 РНР Виза 
2022 


42 


аос*гте:зспета:ираа*е 


$ рир 61п/сопзоте дос+гтпе: зсПема: орда е --дитр-$91 


СКЕАТЕ ТАВЁЕЕ ргодиуст 


$ рир Б1п/сопзо1е досЕг1пе: зспема: ирда*е --дитр-$01 


[0К] МоЕР1пд фо ирдафе - уоуг дафабазе 1$ а\геаЧу 1п зупс млеП Ве 
сиггепф епф1фу тетадажа. 


2022 


Кизэа 


43 


Хелпер проверки схемы в Маке!!е 


Аа6-спеск-5српета-ч1++: 
@рв_ОТЕЕ=`рЮр 6Б1п/соп$о1е Чос+г1те : зсВемта : оирда*е --дитр-$91`; 
сазе "$$0В_ОТЕЕ" 1п 
*'уоиуг Дафабазе 1$ а\геаЧу 1п зупс'х) 
еспо 'Уоуг дафабазе 1$ а\геаЧу 1п зупс м1{П {Пе тефадата"; 


ех1{ 0; 
71 


езас; еспо "$$0В_ОТЕЕ"; ехл+ 1; 


а 
2022 


Кизэа 
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Контроль схемы данных 


# создаем базу и схему данных через миграции 
$ рПр Б1п/сопзоТе досЕг1пе: дафаразе : сгеа*е -п 
$ рИр 61п/сопзоТфе досфг1пе: ттдга*1 оп : п1огаее -9 


45 


Контроль схемы данных 


создаем базу и схему данных через миграции 
рНр 61п/соп$оТфе Чосфг1пе: дафаразе : сгеа*е -п 
рЮр Б1п/соп$оТе досг1пе: ттога* Топ: ттдга*е -а9 
проверяем, что схема соответствует модели 
таке 96 -сНеск-зсНета-ате+ 


© + © = = 


46 


Контроль схемы данных 


создаем базу и схему данных через миграции 
рНр 61п/соп$оТе Чосфг1пе: дафаразе : сгеа*е -п 
рЮр Б1п/соп$оТе досг1пе: ттога* Топ: ттдга*е -а9 
проверяем, что схема соответствует модели 
таке 96-сНеск-зсНета-ат++ 


5 + © 9 = 


проигрываем до первой (4омп) и снова до последней (ур) 

рёр Б1п/соп$о1е досг1пе: ттога*10оп$:т1дгафе -д 90000000000000 
рЮр Б1п/соп$оТе досЕгтпе: ттога*Топ$ :п1тдга*е -9 

таке Ч6-спеск-$спета-Ч91т++ 


&5 = = + 


477 


Контроль схемы данных 


5 + © 9 = 


&5 = = + 


295 


создаем базу и схему данных через миграции 
рНр 61п/соп$оТе Чосфг1пе: дафаразе : сгеа*е -п 
рЮр Б1п/соп$оТе досг1пе: ттога* Топ: ттдга*е -а9 
проверяем, что схема соответствует модели 
таке 96-сНеск-зсНета-ат++ 


проигрываем до первой (4омп) и снова до последней (ур) 

рёр Б1п/соп$о1е досг1пе: ттога*10оп$:т1дгафе -д 90000000000000 
рЮр Б1п/соп$оТе досЕгтпе: ттога*Топ$ :п1тдга*е -9 

таке Ч6-спеск-$спета-91т++ 


валидируем средствами доктрины 
рр арр/соп$оТе Чосфг1пе: зспема : ма\1Ча\е 


48 


Контроль схемы данных 


создаем базу и схему данных через миграции 
рНр 61п/соп$оТе Чосфг1пе: дафаразе : сгеа*е -п 


5- ЗЕ < © + 
и® 
> 
и® 
© 
ее. 
—Э 
—. 
[Ф) 
(©) 
5 
[9] 
(©) 
— 
[99] 
о. 
(©) 
[Ф) 
Ги № 
5 
ее. 
5 
[5] 
5 
ее. 
| ®) 
> 
[@Ъ) 
[ив 
ее. 
(©) 
5 
5 
ее. 
| ®) 
> 
_© 
СЕ 
[Чу 


рЮр Б1п/соп$оТе досЁгтпе: ттога*Топ$ :п1тдга*е -9 
таке Ч6-спеск-$спета-ат++ 


&5 = = + 


валидируем средствами доктрины 
рр арр/соп$оТе Чосфг1пе: зспема : ма\1Ча\е 


& ЗЕ 


49 


Контроль схемы данных 


создаем базу и схему данных через миграции 
рНр 61п/соп$оТе Чосфг1пе: дафаразе : сгеа*е -п 
рНр 6Б1п/соп$оТфе Чосфг1пе: ттдга*1 оп: птогахе^ 
проверяем, что схема соответствует модели 


паке а6-спеск-$спета-91 ++ Г Аа 


®5 Е = => = 


рЮр Б1п/соп$оТе досЕгтпе: ттога*Топ$ :п1тдга*е -9 000000098а9000 
рЮр Б1п/соп$оТе досЁгтпе: ттога*Топ$ :п1тдга*е -9 
таке Ч6-спеск-$спета-ат++ 


&5 = = + 


\ 
валидируем средствами доктрины Среойе. 


рр арр/соп$оТе Чосфг1пе: зспема : ма\1Ча\е 


295 


проигрываем до первой (Чомп) и снова до последее "во. сг7 


2, РНР Виза 
2022 


Миграции 


Миграции 
Кейс 1. Заполнение колонки 


=, РНРРВизза 
2022 


Модель Ргодис* 


рпргу$$1а2022=# \9 ргодисЕ 
ТабТе "рубТ1с.ргодуст" 
СоТитп | Со\Таф1оп | Ми\1ЛаБбТе | Оефаит+ 
---------- неее = 
1п*%едег | поф пилл | 
спагасфег \магу1п9(255) | поф пищ | 


рг1се питег1с (10, 2) | поф пил | 


сиггепсу | спагасфег \уагу1п9(10) | | МОЕЕ :; спагасфег уагу1пд 


]Тпдехез: 
"ргодисф_ркеу" РАТМАВУ КЕУ, Бтгее (19) 


Кизза 
2022 


55 


Модель Ргоаицс*. 1О0ОО тм!п гомз 


рНргу$$1а2022=# зе\есф соипт(*) Ргот ргодис*; 


100 000 000 
(1 гом) 


а 
2022 


Кизэа 


Делаем сиггепсу по{ пий 


@@ -28,7 +28,7 @@ с\азз Ргодиуст 
рг1\уафе $рг1се; 


/** 


*/ 


рг1уафе $сиггепсу; 


РНР Низза 
2022 
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Делаем сиггепсу по{ пий 


Е1па\ с\а$$ ехфепЧ$ Аб$тгасМтогаетоп 


4 


руб11с РопсЕ1оп ир(Зспета $зспета): \019 


4 
} 


$Е115—а99$491('АЕТЕВ ТАВЕЕ ргодус+ АЕТЕВ соггепсу $ЕТ МОТ МИ '); 


риб\1с РипсЕ1оп домп($спета $зспета): \мо19 


4 
} 


$Е115—а99$491('АЕТЕВК ТАВЕЕ ргодисе АЕТЕВ сиоггепсу ОВОР МОТ МИ '):; 


2022 


Кизза 
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Делаем сиггепсу по{ пий 


$ рИр 61п/соп$оте досЕг1пе: т1дга*1оп$ : птогафе -п 
[п0%1се] Мтдга{1та ир фо Бос+г1пемтога*1оп$ \\Мег$10п20221025145525 


п Соппесфтоп.рИр Т1пе 69: 


ЗДЕЗТАТЕ[ 25502]: №1 пидт утота1оп: 7 ЕККОК: со\утп "суггепсу" 


сопфалп$ пи 1 уа\ие$ 


„ма ® 


а 
2022 


Кизза 
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Самый очевидный фикс 


1па\ с\а$$ ехфепЧ5 АбзфгасЕМтдгаттоп 


{ 
руб\1с РопсЕ1оп ир($сНета $зсрпета): \014 
И 
$1115—а99$91('ИРВАТЕ ргоЧиусф $ЕТ сиггепсу = ? МНЕВЕ соггепсу 1$ МИШЕ', 
$+115—2а99$91('АЕТЕВ ТАВЕЕ ргодисе АЁЕТЕВ соггепсу $ЕТ МОТ МЕ '); 
т 


руб 11с РипсЕ1Топ домп($спета $зспета): \мо19 


4 


$+115—а99$91('АЕТЕВ ТАВЕЕ ргодисе АЁЕТЕВ соггепсу ОВОР МОТ МИ '); 
} 


[1950 2; 


Кизэа 


Проблемы реализации 


1. В таблице 100 млн записей 


Проблемы реализации 


1. В таблице 100 млн записей 


2. Миграция выполняется в транзакции 


Проблемы реализации 


1. В таблице 100 млн записей 
2. Миграция выполняется в транзакции 


5. Лок миграцией рантайм-запросов к БД 


1. Делим миграцию на две 


Ар тгасЕМтдга*е1топ 
(Зспета $зсйепта) 


( 


62 


1. Делим миграцию на две 


1па\ с\а$$ ехфепЧ5 АбзфгасЕМтдгаттоп 


4 


рубТ1с РопсЕ1оп ир($сНета $зсрпета): \014 


И 
$4+115—а99$91('АЕТЕВ ТАВЕЕ ргодисе АЁЕТЕВ соггепсу $ЕТ МОТ МЕ '); 


} 


руб 11с РипсЕ1Топ домп($спета $зспета): \мо19 


4 


$+115—а99$91('АЕТЕВ ТАВЕЕ ргодисе АЁЕТЕВ соггепсу ОВОР МОТ МИ '); 
} 


Кизэа 


2. Выключаем транзакционность 


1па\ с\а$$ ехфепЧ5 АбзфгасЕМтдгаттоп 
{ 
руб11с РипсЕ1оп ир($сНета $зсНета): \014 
Л 
$Е115$—а4949$91 ( 
'ОРВАТЕ ргоЧисЕ $ЕТ сиггепсу = ? МНЕВЕ сиггепсу 1$ МИЕЕ', ['0$0'] 


руб\11с РипсЕТоп 1$Тгапзас1опа\(): Боо\ 


гефигп Та\$е; 


Визза 
65 = 2022 


5. Обновляем порциями 


(Зспета $зспета) 


Ф$тахТа = $4115 —>соппест1 оп 


( Фтахта) + 
} 


фсуг$ог - 
(Фсог$ог Ф$тахта) {+ 
$4115 ( 


[ ‚ фсигзог, $сиг$ог [ТМТТ < фтах1ТА ? $сигзог [ТМТТ : $тах1Та] 


р 


фсуг$5ог РМТ. 
| 


$4115 ( 


[ ‚ фтахТа] 
): 


5. Обновляем порциями 


(Зспета $зспета) 


$тахТа = $4115 —>соппесе1 оп 


( Фтахта) + 
} 


фсуг$ог - 
(Фсог$ог Ф$тахта) {+ 
$4115 ( 


[ ‚ фсигзог, $сиг$ог [ТМТТ < фтах1ТА ? $сигзог [ТМТТ : $тах1Та] 


р 


фсуг$5ог РМТ. 
| 


$4115 ( 


[ ‚ фтахТа] 
): 


5. Обновляем порциями 


(Зспета $зспета) 


Ф$тахТА = $4115 —>соппесе1 оп 


( Фтахта) + 
} 


фсуг$ог : 
(Фсог$ог Ф$тахта) + 
$4115 ( 


[ ‚ фсигзог, $сиг$ог [ТМТТ < фтах1ТА ? $сигзог ГТГ ° фмахга] 


р, 


фсуг$ог РЕМ, 
| 


$4115 ( 


[ ‚ фтахТа] 
): 


5. Обновляем порциями 


(Зспета $зспета) 


Ф$тахТа = $4115 —>соппест1 оп 


( Фтахта) + 
} 


фсуг$ог - 
(Фсог$ог Ф$тахта) + 
$4115 ( 


[ ‚ фсигзог, $сиг$ог [ТМТТ < фтах1ТА ? $сигзог [ТМТТ : $тах1Та] 


р, 


фсуг$5ог РЕМ Г) 
| 


$4115 ( 


[ ‚ фтахТа] 
): 


5. Обновляем порциями по а 


рйргу$51а2022=# ехрТалп УРОАТЕ ргодист 5ЕТ суггепсу = '150' МНЕВЕ 
рИргу$$1а2022-# 19 > 50000 АМО 149 < 60000 АМО сиггепсу Т$ МУ; 
(УЕКУ РЕАМ 


Ордафе оп ргодиусф (со$1=429.33.. 3100.73 гом$=7943 м19%П=87) 
— В1%тар Неар 5сап оп ргодусЕ (со$1=429.33..3100.73 гом$=7943 м1а{п=87) 


Кеснеск Сопа: ((14 > 50000) АМО (14а < 6909000)) 
Рег: (соуггепсу 1$ МИ) 
— В1%тар Тпдех $сап оп ргодис*_ркеу (со$1=0.00..427.35 гом$=9893 млаЕН=0) 
ТпЧех ГопЯ* ((149 > 50000) АМО (14 < 60000)) 
РТапп1пд Тлме: 0.071 м$ 


Ехесу{1оп Т1те: 1.298 пт$ 


5. Обновляем порциями через ЕТМТТ/ОЕЕЗЕТ 


рНргу$$1а2022=# ЕХРЕАТМ ПРОАТЕ ргодисЕ $ЕТ сиггепсу = '1$0' МНЕВЕ 19 ТМ ( 
рИргу$$1а2022-# ЗЕГЕСТ 19 ЕКОМ ргодисе МНЕКВЕ соггепсу 1$ МИЕ ОВОЕК ВУ 149 АЗС ЕТМТТ 10000 ОРРЗЕТ 50000 
рНргу$$1а2022-# ); 


ЧУЕКУ РЕАМ 


Ордафе оп ргодисЕ  (со$%=4643.84..8541.87 `0\$=10000 м1аЕв=114) 
—› НазНн 5ет1 до04п (с0${=4643.84..8541.87 гом$=10000 м1атп=114) 
Назп Сопа: (ргодусф.14а = "АМУ_зибауегу".1а) 
— 5е4а 5сап оп ргодиусф (со$1=0.00..3524.01 гом$=100101 мзатв=48) 
— Назнй (с0$4=4518.84.. 4518.84 гом$=10000 м19Ев=32) 
— биБацегу $сап оп "АМУ_зибауегу" (со$1=3682.44.. 4518.84 гом$=10000 м1аен=32) 
— 1111 (с0${=3682.44.. 4418.84 гош$=10000 мтаЕп=4) 


—› Та4ех $сап и$1п9 ргодис+_ркеу оп ргодисЕ ргодисе_1 (с0$%=0.42..7371.89 гом$=100101 мтав=4) 
Рег: (сиггепсу 1$ МИЕ) 


РЛапп1пд Т1ме: 0.502 пт$ 


Ехеси1оп Т1ме: 835.349 т$ 
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Как результат 


1. Не мешаем гипите приложения [оскК'ами при 
деплое 
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Как результат 


1. Не мешаем гипите приложения [оскК'ами при 
деплое 


2. Можно поэтапно деплоить каждую миграцию 


=, РНР Ризза 
2022 
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Как вести себя приложению во 
время наката миграции? 


Миграции 
Кейс 2. Миграция 1-1 в 1-М 


74 


Делаем множество цен утоваров 


14 5егта( 
пате 5Ег1п9 
ргтсе дестта\ 


сиггепсу 5ЕгГ1п9 
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Делаем множество цен утоваров 


ргодуст _рг1се 


10 сег1а\ 14 5егта\ 
пате 5ЕгГ1п9 ргодуст_19 ИЕ 
ргтсе Чеслта\ 


сиггепсу 5Ег1п9 
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Этапы миграции. 1 этап 


10 5егла( 
пате 5Ег1п9 
рг1се дестта\ 


сиггепсу 5Ег1п9 


ргодуст _рг1се 


14 5егта( 
ргодуст_19 11% 
рг1се дестта\ 


сиггепсу 5Ег1п9 
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Этапы миграции. 2 этап 


ргодуст _ргтсе 


10 5егта\ — и 5егта\ 
пате 5Ег1п9 ргодуст_19 ИЕ 


ОРТСЕ Чеслта\ ————»> ргтсе Честпа\. 


суггепсу гПа + СиГГеПСу 5Ег1 пд 
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Этапы миграции. 5 этап 


ргодуст _рг1се 


10 сегта\1. 10 


5егта\ 
пате 5Ег1п9 ргодуст_19 ИЕ 
рг1се дестта\ 


сиггепсу 5Ег1п9 


В виде одной миграции 


(Зспета $зспета) 


(<<<$ 0 


( 
(<<<$ 0 


В виде одной миграции 


(слета $зспета) 


(<<<$ 0 


( 
(<<<$01 


В виде одной миграции 


(Зспета $зспета) 


(<<<$ 0 


( 
(<<<$01 


В виде одной миграции 


(Зспета $зспета) 


(<<<$ 0 


( 
(<<<$ 0 
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Вводные 


1. Большая таблица товаров +100 млн записей 


Вводные 


1. Большая таблица товаров +100 млн записей 


2.Постоянная нагрузка 100 ООО {рз к базе 
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Вводные 


1. Большая таблица товаров +100 млн записей 
2.Постоянная нагрузка 100 ООО {рз к базе 


5.Минимизировать локи при внедрении 
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Вводные 


1. Большая таблица товаров +100 млн записей 
2.Постоянная нагрузка 100 ООО {рз к базе 
5.Минимизировать локи при внедрении 


4.Обеспечить работу во время внедрения 


ВСЕ ОЧЕНЬ 


Локи, отказы 
приложения и 
БОО-ые ;%!!3(( 


Ро РНР Ризза 
2022 


Разделим на несколько 
миграции и перенесем 
данные порциями! ®© 
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Есть проблемки 


1. Да, снижается вероятность локов 
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Есть проблемки 


1. Да, снижается вероятность локов 


2.Но длительность внедрения увеличивается 


=, РНР Ризза 
2022 
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Есть проблемки 


1. Да, снижается вероятность локов 
2.Но длительность внедрения увеличивается 


5. А если внедрение длится час? 


92 


Есть проблемки 


1. Да, снижается вероятность локов 
2.Но длительность внедрения увеличивается 
5. А если внедрение длится час? 


4. При этом код еще со старой или уже с новой 
моделью 


=, РНРРизза 
2022 
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[Шаг]. Пишем в обе, читаем из старой 


1. Миграция. Создаем новую к ни 
таблицу пате 51г1п9 
——> рг1се Чес1тат *, 
2. Пишем в старые поля, =————> ПИБ . ^,. 
дублируем в новые х 
5. Читаем из старых полей 14 зега\ Л 
ргодис+_19 и ., 
А. Логика приложения старая ОТК ”. 


(одна цена) сиггепсу — э%г1пд 


2, РНР Виза 
2022 


[Шаг]. Пишем в обе, читаем из старой 


1. Убеждаемся, что правильно 


10 5егта\ 
заполняется новая таблица папе Его 
‚2 рг1се Чес1тат *, 
% 
2. Едем дальше ж_ сиггепсу $%г4пд *, *, 
те 
р $1 
14а сегта\ К, 
и 
ргодус+_19 п ’_ 
№ 4 
рг1се Чес1та\ — 
Г 


сиггепсу 5ЕГ1п9 


2, РНР Виза 
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УЗ 


Шаг2. Пишем в обе, читаем из старой 


1. Миграция. Переносим Е ни 
порциями старые данные в папе 5-го 
нов\ю табли рг1се Честта\ `.. 

У ЧУ сиггепсу 5Г1п9 т 

2. В моделях ничего не ` 

: 
трогаем 14а сегта1 ‚ 

5. Логика приложения старая И т 


рг1се дестта\ » 


(одна цена) к 


сиггепсу 5ЕГ1п9 


2, РНР Виза 
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Шаг2. Пишем в обе, читаем из старой 


1. Убеждаемся, что новая и та 
таблица имеет все записи папе 5ЕГ1п9 


рг1се десттат *› 


2.Едем дальше 


сиггепсу 5{г1п9 * * 


ъ*% 

$ \ 

® $1 

ргодиус* _ргасе ;. 

10 5егта\ К, 

М: — ргодист_19 Чип 
| ы’, 
рг1се Чес1та\ — 

Г 


сиггепсу 5ЕГ1п9 


2, РНР Виза 
2022 
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Шаг 5. Пишем в обе, читаем из новой 


1. Нет миграций 


10 5егта\ 
2. Пишем в новые поля, ре ЕЕ 
рг1се дестта\ > 
дублируем в старые БОЕ: САИ ›-. 
5. Логика приложения старая > 
(одна цена) а зег1а1 1 
ргодус+_1а 111 к 
———> ргсе Чеслтат ›’,” 


м—_ сСиггепсу 5ЕГ1п9 


&2, > РНР Виза 
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Шаг 5. Пишем в обе, читаем из новой 


1. Убеждаемся, что изменения 


19 5егта\ 
летят в новую таблицу пате 51г1п9 

рг1се дестта\ > 
2. Едем дальше сиггепсу — $5%г1пд >. 

р Е \ 
58 С этого и предыдущих р ВЫ |, 

ргодусЕ_19 п Ра 
шагов есть ВОЗМОЖНОСТЬ с м 
откатиться < ^^ сиггепсу э4гтд .-” 


&2, > РНР Виза 
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Шаг 4. Открываем фичу множественных цен 


1. Нет миграций з4 зегза\ 
пате 5Г1Тп9 
2. Пишем только в новые поля 
рг1тсе Чеслта\. > 
5. Логика приложения новая т А 
(множественные цены) | 
14а сегта\ 
ргоЧиусЕ_14 тп 
5 Фича множественных __ ь ржеииииня 
цен работает! =<____^ сиггепсу ${г1п9 


&2, > РНР Виза 
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Шаг 5. Подчищаем старое 


1. Миграция. Удаляем поля в 
гост 


2.Удаляем поля в модели 


5. Логика приложения новая 
(множественные цены) 


10 сегта\ 


пате 5Г1Тпд 


х 


я 


ргодис* _ргтсе 


10 5егта\ 
ргоЧиусЕ_14 тп 
рг1се дестта\ 


сиггепсу 5ЕГ1п9 


2, РНР Виза 
2022 


Миграция 1-1 в 1-М. Итого 


— Внедрение многоэтапное и длительное 
+ Минимизируем локи 
+ Минимально аффектим работу приложения 


+ В случае ошибок можно откатиться обратно 


=, РНРРизза 
2022 


Индексы 


195 


оое Ш. 


Продажи 


Заказы 


Клиенты 


‚ Список 


Корпоративные 
Программа лояльности 
Письма 


$М5 


Товары и склад 
Менеджеры 


Финансы 


7 Инструкции по настройке 


+ Добавить ссылку 


© В аето.гейайсгт.ги/сизютег$/42#Н-юод-а! $8 ©, ©) [М + 


Главная - Клиенты - 


Клиент Изольда Данилова 


ОСНОВНЫЕ ДАННЫЕ История изменений 


Г Данилова Изольда 
< Ь $7 Жен. 
Россия 


Ростов-на-Дону 


Ладыгина, д. 82, кв./офис 26 


(35222) 69-8260 
(812) 057-47-11 
(495) 376-1166 
(495) 873-1598 


аго$|ауа.Багапоуа@тай.ги 


Теги 


+ Добавить 


Сегменты 


Клиенты из городов... Украина 
Средней давности Большая сумма пок... 
Большой [ТУ Высокий средний чек 
Разовый клиент Только 1 отмена 


Женщины 


Все 


© 


7 


и’ Редактировать 


{27 Новый заказ 


Заказы @ Задачи [2 Заметки @ Письма | 42) $М$ Е Еще ` 


Создана задача Перезвонить Демо-магазин ^ 24.10.2022, 22:41 


Назначена Кузьма 
Заказ 33С 
Заметка Демо-магазин * 23.10.2022, 04:28 


Хочет открыть магазин "Радиоуправляемые модели" 100 кв. м. Отправил 
предложение для оптовиков. 


Назначен в сегмент Клиенты из городов- 


 МмиллиОнников Демо-магазин ` 22.10.2022, 10:49 


ыы в сегмент Высокий средний Демо-магазин - 14.10.2022, 22:53 


Исходящее письмо Раздаём промокоды 


до 5000р. Только сегодня!" Демо-магазин ` 24.09.2022, 11:00 


Получатель юигае$.${гозт@уаНоо.сот 


Статус (©) Доставлено 


изза 
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оое Ш. 


Продажи 


Заказы 


Клиенты 


‚ Список 


Корпоративные 
Программа лояльности 
Письма 


$М5 


Товары и склад 
Менеджеры 


Финансы 


7 Инструкции по настройке 


+ Добавить ссылку 


© В дето.ге{айсгт.ги/с 


Главная -> Клиенты -> 


Клиент Изольда Данилова 


ОСНОВНЫЕ ДАННЫЕ История изменений 


Г Данилова Изольда 
\ 


* $7 Жен. 


Россия 
Ростов-на-Дону 


Ладыгина, д. 82, кв./офис 26 


(35222) 69-8260 
(812) 057-47-11 
(495) 376-1166 
(495) 873-1598 


аго$|ауа.Багапоуа@тай.ги 


Теги 


+ Добавить 


Сегменты 


Клиенты из городов... Украина 
Средней давности Большая сумма пок... 
Большой [ТУ Высокий средний чек 
Разовый клиент Только 1 отмена 


Женщины 


егз/42#Н-10д-а! 68 с, оф + 


{27 Новый заказ /’ Редактировать 


Заказы [4 Задачи [2 Заметки @ Письма | 42) $М$ Е Еще ` 


Создана задача Перезвонить Демо-магазин ^ 24.10.2022, 22:41 


Назначена Кузьма 
Заказ 33С 


Заметка Демо-магазин * 23.10.2022, 04:28 


Хочет открыть магазин "Радиоуправляемые модели" 100 кв. м. Отправил 
предложение для оптовиков. 


Назначен в сегмент Клиенты из городов- 


 МмиллиОнников Демо-магазин ` 22.10.2022, 10:49 


Назначен в сегмент Высокий средний 


чек Демо-магазин * 14.10.2022, 22:53 


Исходящее письмо Раздаём промокоды 


до 5000р. Только сегодня!" Демо-магазин ` 24.09.2022, 11:00 


Получатель юигае$.5{гозт@уаНоо.сот 


Статус (©) Доставлено 


55а 


1905 


Лента событий клиента 


14 сегта\ — та 
ТеЕтег_14 


са1\_19 
ВОИ кони 


зеглат м 41а109_19 
Тазк_19а 


огдег_14 


10 сеглаф ———4 °.. 


сузфотег_емепе са11. 


сегта\ 


в— 10 5егта\ 
ИЕ 
ТП 
пи Ш——_ О зег1а\. 
АЕ 
171 огдег 

и——_щ О зег1а\ 


оссиггед_а{ Т1тезфатр 


=, РНР Виза 
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Автоиндексы от Вос*гте 


рИргу$$1а2022=# \9 сиузфотег_емеп* 


Тпдехез: 
"сизфотег_ емеп{ рКеу1" РЕТМАКУ КЕУ, Бфгее (14) 
"19х_664762244525++26" Б\%гее (Тетег_194) 
"19х_6647622450а8962с" Б+гее (са1\_19) 
"19х_664762245е46с4е2" Бфгее (91а1о9_14) 


Рогетап-Кеу соп5{гатпт$: 
"ЕК_6647622445254+26" РОВЕТбМ КЕУ (Теффег_19) ВЕРЕВЕМСЕЗ Теффег (19) ОМ ОЕГЕТЕ САЗСАОЕ 
"-К_6647622450а8962с" РОВЕТбМ КЕУ (са\\_19) ВЕРЕКЕМСЕ$ са1Т (14) ОМ ОЕГЕТЕ САЗСАОЕ 
"-К_664762245е46с4е2" РОВЕТбМ КЕУ (91а109_149) ВЕРЕКЕМСЕ$ тд_Ч91а1од9 (149) ОМ ОВЕГЕТЕ САЗСАОЕ 


Размер индексов 


рНргу$$1а2022=# зе\фесеф соип*(*) Ргом сизфотег_еуеп*; 


5428887 


(1 гом) 


рйргу$$1а2022=# 
фаб\е_пате | сабте 1пдех фофа\ 


суизфотег_е\меп* | 276 МВ | 1398 МВ | 1674 МВ 
(1 гом) 


Структура данных в су$Тотег_еуепт 


рИйргу$$1а2022=# зетест су5фотег_емеп{ 111+ 9; 


| Тееег_та | _19 | са\_19 | 91а\о9_19 | фазк_1а | огаег_1а | оссиггед_а* 


1540455 2018-01-09 
1544286 2018-0111 
1544287 122452 2018-01-11 
1544288 29180111 
1544289 2918-01-11 
1544290 122455 2018-91-11 
1544514 504373 2918-01-11 
1544318 504379 2018-01-11 
1549031 2918-91. 15 


(9 гом$) 


РНР Низза 


2022 
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Рагца| паехез 


=, РНР Ризза 
2022 


110 


Рагпа| паехез 


=# СВЕАТЕ ТМОЕХ 19х_664762246495с7е60 ОМ сизфотег_еумепе ($т$_19) 


В индекс добавляются только записи таблицы, 
подпадающие под условие 


Переводим на рагЧа| паехез 


рИргу$$1а2022=# \9 сузфотег_емеп* 


Тпдехез: 
"сизфотег емеп{ рКеу1" РЕТМАКУ КЕУ, Бфгее (14) 
"19х_664762244525++26_пофпу11" Б+гее (Те{ег_149) МНЕВЕ Те{+ег_149 1$ МОТ МИ 
"19х_6647622450а8962с_пофпи11" Б{гее (са1\\_19) МНЕВЕ са1\_19 1$ МОТ МИ 
"19х_664762245е46с4е2_пофпу\1" Б+гее (91а1о9_149) МНЕВЕ Ч1а1о9_149 Т$ МОТ МИ 


Рогездп-Кеу соп5{га1пт$: 
"ЕК_6647622445254++26" РОВЕТбМ КЕУ (Теффег_19) ВЕРЕВЕМСЕЗ Тее\фег (19) ОМ ОЕГЕТЕ САЗСАОЕ 
"-К_6647622450а8962с" РОВЕТбМ КЕУ (са\\_19) ВЕРЕКЕМСЕ$ са1\Т (149) ОМ ОЕГЕТЕ САЗСАОЕ 
"-К_664762245е46с4е2" РОВЕТбМ КЕУ (91а109_149) ВЕРЕКЕМСЕ$ тд_Ч91а1од (149) ОМ ОВЕГЕТЕ САЗСАОЕ 


Обновленный размер индексов 


рНргу$$1а2022=# зе\тесеф соип*(*) Ргом сизфотег_еуеп*; 


5428887 
(1 гом) 


рИргу$$1а2022=# ... 

Таб\1е_пате | табле | 1пдех | фофа\ 
ен - Неее нае 
су$+отег_е\мепЕ | 276 МВ | 428 МВ | 704 МВ 
(1 гом) 


На уровне Вос\гте 


5ег\1сез: 
Арр\ОВАЕ \$спета\ТпЧехМ 1 $Спапдег: 
агдитептс: 


- '@аппофа{1топ_геадег"' 
Тад$: 
- { пате: досег1пе.еуеп*+_115%епег, е\уеп*: ро5%бепегафе$спетаТаБТе } 


| Кизза 
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Собственные рагиа! паехез 


/хх 
х @0РМ\Табте( 
пате="Тад", 
1пдехе$=1{ 
@ОРМ\Тпаех( 
пате="тад_пате_де1тетед_а{_15$пи11_тпа", 
соТитп5={"пате"}, 


) 


х 
я 
х 
р 
х 
* орт1оп5=1 "иреге"="дететед_ат 1$ МИЁЕ"} 
х 
я 
х 
* 
х 


@ОРМ\ЕпттТту (геро$1ТогуСТа$$="ТадВеро$1Тогу :: ста$5") 


а 
2022 


Кизэа 
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Но если хочется большего? @>5 


=, РНР Ризза 
2022 
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Индексы на выражения 


1_с1пдех_614494115с8061с66934701с1Ре15та1 


ргодиусЕ (Томег(пате)); 


Индексы на выражения 


ргоЧусЕ Томег (паме) = '99аа6210ас590с695754983е249350686с1 '; 
ОУЕКУ РЕАМ 


В1{тар Неар 5сап оп ргодисЕ (с0$1=20.29..783.05 гом$=500 м19%Н=37) (асфиа\ +1те=2.219..2.223 гом$=1 1оор$=1) 
Кеспеск Сопа: (Томег((пате) :: +ех*) = '99аа6210ас590с69575983е24930686с1' :: +ех+) 
Неар ВТоск$: ехас*=1 
—› В1фтар Тпаех 5$сап оп 1_с1п4ех_6144494115с8061с66934701с1Ре15+а1 (со$1=0.00..20.17 гом$=500 изаев=0) 
Тпдех Соп@: (Томег((пате) :: +ех{) = '99аа6210ас590с69575983е2930686с1 ' :: Хех+) 
РТапп1пд Т1те: 1.577 м5 


Ехеси{1оп Т1ме: 2.263 м$ 
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Другие типы индексов 


1_с1пдех_е716сс+е22821815а701с1с8е954а679 


ргодиус- 91п (Томег(пате) 91п_1гдт_ор$); 


Другие типы индексов 


ргодусе Томег (пате) '%219ас590с695754983е%'; 
ОУЕКУ РЕАМ 


В1{тар Неар $сап оп ргодисЕ (с0$%=196.08..232.94 гом$=10 м19%Н=37) (асфиа\ +1те=2.131..2.132 гом$=1 10оор$=1) 
Кеснеск Сопа: (Томег ( (папе) :: ех*) ^^ '%210ас590с69575483е%' :: Хех+) 
Неар ВТоск$: ехас*=1 
—› В1фтар Тпаех 5$сап оп 1_с1п4ех_е716ссРе2282+815а701с1с8е954а679 (со$1=0.00..196.07 гом$=10 изаев=0) 
Тпдех Соп@: (Томег( (пате) :: +ех{) ^^ '%210ас590с695754983е%' :: ех+) 
Р\Тапп1пд Т1тме: 1.058 м5 


Ехеси{1оп Т1ме: 2.854 т$ 


Но Эос%гте ОВМ не умеет 


1пфаго /сузфот-1пдех-рБопаТе 


=, РНР Ризза 
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Описание индексов в модели 


Арр\Реро$1Тогу\Ргодис+Керо$1тогу; 
бос+г1пе\ОРМ\Марр1 пд ОВМ; 
]пфаго\Соу$фотТпдехВипаТе \Аппота*1Топ$ 


Ргодусе 


Создание индексов в БД 


61п/соп$о1е 1пжаго: дос+г1те : 1пдех : ирда{е 


Зииттагу 


Что в итоге 


1. Эффективно подключаемся к Роз{эге О! 
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Что в итоге 


1. Эффективно подключаемся к Роз веге О 


2.Контролируем время выполнения запросов и время на 
Локи 
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Что в итоге 


1. Эффективно подключаемся к Роз еге ОЕ 


2.Контролируем время выполнения запросов и время на 
Локи 


5. Управляем структурой БД через модель данных 


=, РНР Ризза 
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Что в итоге 


1. Эффективно подключаемся к Роз еге ОЕ 


2.Контролируем время выполнения запросов и время на 
Локи 


5. Управляем структурой БД через модель данных 


д. Следим за синхронностью модели и схемы данных 


=, РНР Ризза 
2022 


129 


Что в итоге 


1. Эффективно подключаемся к Роз еге ОЕ 


2.Контролируем время выполнения запросов и время на 
Локи 


5. Управляем структурой БД через модель данных 
4. Следим за синхронностью модели и схемы данных 


5. Внедряем «тяжелые» фичи, не влияя на работу 
пользователей 
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Что в итоге 


1. Эффективно подключаемся к Роз еге ОЕ 


2.Контролируем время выполнения запросов и время на 
Локи 


5. Управляем структурой БД через модель данных 
4. Следим за синхронностью модели и схемы данных 


5. Внедряем «тяжелые» фичи, не влияя на работу 
пользователей 


6. Строим оптимальные индексы 


Спасибо Бобросый а 
|| Г | доклад :) -& 


| | 
| 


И 
| | | / —. 


и Ил ьяс Сал ихов /_ 
| В: @зайкном_ Нуаз. 
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